// pages/recommendSongs/recommendSong.js
import Pubsub from 'pubsub-js';
import request from '../../utils/request';

Page({

  /**
   * 页面的初始数据
   */
  data: {
    day: '', // 天
    month: '', // 月
    recommendList: [], // 推荐列表数据
    index: 0, // 点击音乐的标识
  },

  /**
   * 生命周期函数--监听页面加载
   */
  onLoad(options) {
    // 判断用户是否登录
    let userInfo = wx.getStorageSync('userInfo');
    if(!userInfo){
      wx.showToast({
        title: '请先登录！！',
        icon: 'error',
        success: () => {
          // 跳转至登录界面
          wx.reLaunch({
            url: '/pages/login/login',
          })
        }
      })
    }
    // 更新日期状态数据
    this.setData({
      day: new Date().getDate(),
      month: new Date().getMonth() + 1
    })
    // 获取每日推荐数据
    this.getRecommendList();
    // 订阅songDetail页面的消息
    Pubsub.subscribe('switchType', (msg, type) => {
      let {recommendList, index} = this.data;
      if(type === 'pre'){
        // 切换至上一首
        (index === 0) && (index = recommendList.length)
        index -= 1;
      } else {
        // 切换至下一首
        (index === recommendList.length - 1) && (index = -1)
        index += 1;
      }
      // 更新歌曲标识
      this.setData({
        index
      });
      let musicId = recommendList[index].id;
      // 将musicId传给songDetail页面
      Pubsub.publish('musicId', musicId);
    })
  },

  // 获取每日推荐数据的方法
  async getRecommendList(){
    let recommendListData = await request('/recommend/songs');
    this.setData({
      recommendList: recommendListData.data.dailySongs
    })
  },

  // 跳转songDetail回调
  toSongDetail(event){
    let {song, index} = event.currentTarget.dataset;
    this.setData({
      index
    });
    wx.navigateTo({
      url: '/pages/songDetail/songDetail?musicId=' + song.id,
    })
  },

  /**
   * 生命周期函数--监听页面初次渲染完成
   */
  onReady() {

  },

  /**
   * 生命周期函数--监听页面显示
   */
  onShow() {

  },

  /**
   * 生命周期函数--监听页面隐藏
   */
  onHide() {

  },

  /**
   * 生命周期函数--监听页面卸载
   */
  onUnload() {

  },

  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh() {

  },

  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom() {

  },

  /**
   * 用户点击右上角分享
   */
  onShareAppMessage() {

  }
})